<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <h1>获取所有子节点</h1>
    <h2>节点分类</h2>
    <ul>
        <li>元素节点（标签、DOM）</li>
        <li>属性节点（标签上的属性）</li>
        <li>文本节点（标签的内容）</li>
    </ul>
    <h2>节点对象</h2>
    <p>使用dom对象的childNodes可以获取到所有文本子节点和元素子节点的数组</p>
    <ul>
        <li>nodeType：1（元素），2（属性），3（文本）</li>
        <li>nodeName：标签名|属性名|#text</li>
        <li>nodeValue：null|属性值|文本内容</li>
    </ul>
    <div id="div1">
        <p>我是p1</p>
        <p>我是p1</p>
    </div>
    <button onclick="doIter()">遍历div1</button>

    <script>

        let div = document.querySelector("#div1");

        function doIter() {
            // 获取所有直接子节点：只包括内容节点和元素节点。
            let childNodes = div.childNodes;
            for (let i = 0;i < childNodes.length;i ++) {
                let node = childNodes[i];
                console.log(i,"：nodeType = ",node.nodeType,"，nodeName = ",node.nodeName,"，nodeValue = ",node.nodeValue)
                if (node.nodeType == 3) {
                    node.nodeValue = "文本" + i;
                }
            }
        }
    </script>
</body>
</html>